## COMPLEX DIGITAL SYSTEM VERIFICATION

EEEE-722 Perl Verification Project Assignment

Assigned: Monday, January 10, 2022

| EEEE-722 Perl Verification Project Code Review: | Wednesday, January 19, 2022, In Lab |
|-------------------------------------------------|-------------------------------------|
| Perl Verification Project Submission Due:       | Monday, January 24, 2022, 11:30 PM  |

# Revision History:

| V9 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
|-------|---------------------------------------------------------|
| V8 R2 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V8 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V7 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V6 R2 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V6 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V5 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V4 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V3 R1 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V2 R1 | Updates for EEEE-722 / EEEE-799 by:<br>Mark A. Indovina |
| V1 R2 | Updates for EEEE-722 by:<br>Mark A. Indovina            |
| V1 R1 | Original created for EEEE-722 by:<br>Mark A. Indovina   |

# EEEE-722 Perl Verification Project Page 3 of 13

## TABLE OF CONTENTS

| 1.  | INTRODUCTION           | 4    |
|-----|------------------------|------|
| 2.  | SOURCE CONTROL         | 8    |
| 3.  | PROJECT SUBMISSION     | . 10 |
| 4.  | PROJECT GRADING POLICY | . 11 |
| APP | ENDIX                  | . 13 |

#### 1. INTRODUCTION

The EEEE-722 Perl Verification Project requires development of a program written in the language Perl which generates synthesizable Verilog® HDL, and a companion behavioral testbench, for a multistage pipeline register (similar in fashion to a parallel word shift register) based on the following requirements:

- a. Using the Perl Getopt package (using Getopt is mandatory), accept multiple command line options as follows:
  - i. --help
    - 1. (optional) issue help message and program exits
    - 2. Overrides all other options
  - ii. --param *file name* 
    - 1. (optional) input parameter file
  - iii. --width *nn* 
    - 1. (optional decimal value) operand width
  - iv. --stages nn
    - 1. (optional decimal value) number of pipeline stages
  - v. --reset nn
    - 1. (optional hex or decimal) register reset value
  - vi. --outfile *file name* 
    - 1. (optional) output file name for generated module
    - 2. The *file name* naming convention is as follows:
      - a. The *file name* must be of the format <module name>.v
      - b. <a href="mailto:smodule\_name">module\_name</a> will be extracted and used as the module name of the generated module
      - c. The generated testbench filename will be <module\_name>\_test.v
      - d. the testbench module name will be test
      - e. the testbench device under test will be <module name>
      - f. the testbench device under test instance will be top

Note that the user must pass either "--param" or "--width, --stages, --reset, and --outfile" and any other mandatory options. Passing both "-param" and any other options, or skipping mandatory options is an error for which a message will be issued along with a program usage statement before the program exits. The operand width (1-64 bits wide) and number of pipeline stages (2-128 stages) will be checked for limits, errors will generate a message along with a program usage statement before the program exits.

#### CONTINUED NEXT PAGE

b. The optional input parameter file will be formatted as follows (in any order):

```
width = nn;
stages = nn;
reset = nn; or reset = 0xnn;
outfile = file name;
```

Missing or unknown options will generate an error along with a program usage statement before the program exits. The operand width (1-64 bits wide), number of pipeline stages (2-128 stages), and reset value (to make sure the value passed does not exceed the register width) will be checked for limits, errors will generate a message along with a program usage statement before the program exits.

- c. Use *perldoc* to embed the user manual in the Perl source code.
- d. The generated RTL Verilog® code must compile with xmverilog and synthesize with Synopsys Design Compiler.
  - i. The code will include full-scan DFT ports as shown in the template.
  - ii. The code will include active high, asynchronous reset.
- e. The generated RTL Verilog® code must be straightforward and precise. This means the RTL code is "simple" in nature and CANNOT CONTAIN:
  - i. Macros, parameter's or localparam to "parameterize" the RTL code
  - ii. The RTL code cannot include any loop constructs such as "for" or "while".
- f. The generated Verilog testbench must be self checking
  - i. As noted earlier, your testbench module name must be test and the module under test instance name must be top.
  - ii. Your testbench must include a procedure that checks that your pipeline works properly cycle by cycle based on the number of stages. This includes testing both the reset sequence, and active sequence.
  - iii. Your testbench can (and should) include any loop constructs such as "for" or "while" as necessary for testing.
  - iv. Your testbench must not include any \$stop statements.
  - v. After a fixed amount of testing, your testbench MUST FINISH with a Sfinish statement.
    - 1. The number of test passes must be at least 100 times the number of stages.
  - vi. Your generated Verilog testbench must properly back annotate timing. Note this SDF annotate statement in the template testbench: \$sdf\_annotate("sdf/chkrpl\_tsmc18\_scan.sdf", test.top); Your program should generate this statement with the user configured
    - \$sdf annotate("sdf/<module name> tsmc18 scan.sdf", test.top);
- g. Check your generated Verilog RTL and testbench using the chkrpl database.

module name as:

Page 6 of 13

Requirements for your program:

All work will be source controlled with git – paths shown are based on the source control requirements defined in section 2.

You will create your program in the directory:

eeee722/<RIT\_UID>\_<Semester>/pl

Your program name must be <RIT UID>.pl

Given the above requirements, your program will can be found as:

eeee722/<RIT\_UID>\_<Semester>/pl/<RIT\_UID>.pl

Your program will generate all files in the local directory, eeee722/<RIT\_UID>\_<Semester>/pl, ONLY. THERE WILL BE NO HARD CODED PATHS
EMBEDDED IN YOUR PROGRAM.

DO NOT SUBMIT SOURCE CODE EDITED ON A WINDOWS PC! ALL CODE MUST BE CREATED ON THE LINUX SYSTEM.

The following cannot be used in variable names or comments:

- reg
- 2. register
- 3. Anything containing "reg"

All registers must be individually declared.

Acceptable coding style:

reg [7:0] s1;

reg [7:0] s2;

reg [7:0] s2;

Not acceptable coding style:

reg [7:0] s1,

s<mark>2,</mark>

s3;

Note: RIT\_UID is your RIT computer network logon.

## **CONTINUED NEXT PAGE**

It is strongly recommended that you use a context sensitive editor to author your code. The Linux systems have vim, gvim, and sublime. While vim is a fantastic editor, it will take some practice getting used to the control sequences. Therefore it is recommended that you use sublime.

sublime should already be accessible in your account — just type sublime on the command line and the editor will open.

It not accessible, carefully add the following line the very end of your .bashrc

alias sublime='/classes/eeee720/bin/sublime\_text'

#### 2. SOURCE CONTROL

To start, you will need to create a work area for the project. Logon to one of the CEDA lab computers or compute servers and create the work area for EEEE-722 Perl **Verification** Project as follows:

cd mkdir eeee722 cd eeee722

Now clone the initial repository.

git clone git@kgcoe-git.rit.edu:maieee/<RIT\_UID> <Semester>.git

Where: (i) RIT UID is your computer log on ID; and (ii) Semester is short hand for the current semester (i.e. su2016 is for Summer 2016, f2016 is for Fall 2016).

All work will be source controlled with *qit*:

## git status

If the git status command does not report "nothing to commit (create/copy files and use "git add" to track)", something went wrong – ask for assistance.

Throughout the design and development of the EEEE-722 Perl Verification Project, you must maintain your source code with git, in a nutshell you will be using the following commands daily:

- *qit status* to check the status of the local repository
- git add to add new files to the local repository
- qit commit to commit your changes to the local repository
- *git show* show you repository objects
- *qit loq* show you commit logs
- qit push to push your latest updates back to the master repository
- git pull to pull the latest updates from the master repository

If you get stuck, git help will display of list of git commands, and git help <command> will display a command manual page.

A couple of critical comments on *git*:

## EEEE-722 Perl Verification Project

#### Page 9 of 13

- 1. If you don't know *git*, or feel you are a novice, extensive *git* documentation is available in the *git* website: <a href="http://www.git-scm.com/">http://www.git-scm.com/</a> Also take time to run through a *git* tutorial: <a href="http://try.github.com/">http://try.github.com/</a>
- 2. Many of the *git* commands include a **FORCE ( -f )** option. **NEVER, EVER** use the **FORCE ( -f )** option during the course of this class. If you get stuck, please consult with the instructor.
- 3. The recommended procedure for working with the repository database is as follows:
  - a. Start a work session
    - i. Modify your local repository
    - ii. Add files your repository changes by executing git add
    - iii. Check in your repository changes by executing git commit
    - iv. Modify your local repository
    - v. Check in your repository changes by executing *qit commit*
  - b. Work session complete
- 4. *git commit* forces you to enter comments to document your changes. The comment window is a traditional *vi* window. If you are not comfortable with *vi*, install *gVim* on your personal computer (PC or Mac) and work through the *gVim* tutorial.

## 3. PROJECT SUBMISSION

The **Perl Verification Project** Submission shall be a copy of the Perl program along with a brief user manual authored in LyX (submit an exported PDF copy) that mimics a Unix man page submitted to mycourses – this can be a copy of your embedded user manual.

Note: upload a copy of your Perl program to mycourses with a ".txt" extension added.

Published: 27 December 2021

## 4. PROJECT GRADING POLICY

- 1. Completion of the **EEEE-722 Perl Verification** Project assignment by indicated date and time No Exceptions!
- 2. On the on-on-one code presentation and review of your **EEEE-722 Perl Verification** Project codebase with the instructor: <u>Wednesday</u>, <u>January 19</u>, <u>2022</u>, <u>In</u> Lab.
- 3. On your **Perl Verification Project** Submission copy of the Perl program along with a brief user manual (PDF) submitted to mycourses.
- 4. On your Perl Verification Project Submission database copy, pushed to the Perl Verification Project Submission git repository, due: Monday, January 24, 2022, 11:30 PM.

Published: 27 December 2021 RIT 11

The EEEE-722 Perl Verification Project is graded per the syllabus as a separate item with individual components graded as follows:

**Table 1 Project Grading** 

| Graded Item                          | % of Grade | Notes                                                                                       |
|--------------------------------------|------------|---------------------------------------------------------------------------------------------|
| Perl Verification Project Submission | 5%         | Code Review                                                                                 |
| Perl Verification Project Submission | 75%        | Perl Program: (i) Independent Review By<br>Instructor; (ii) Final Database Submission (GIT) |
| Perl Verification Project Submission | 20%        | Users Guide                                                                                 |
| Total:                               | 100%       |                                                                                             |

#### **APPENDIX**

How to get rid of the black background for printing and documentation purposes:



Figure 1 Sample Schematic - Original Black Background

After you copy/paste the window containing the schematic in a word file, using ALT-PRT\_SCR, right click on the image and select SHOW PICTURE TOOLBAR.

Once the toolbar opens, towards the right hand side there is a command SELECT TRANSPARENT COLOR. Click on it and then click anywhere on the black background in your window. See the result below.



Figure 2 Sample Schematic - Modified White Background